summaryrefslogtreecommitdiff
path: root/src/pages/posts/[...slug].astro
diff options
context:
space:
mode:
authorDawid Rycerz <dawid@rycerz.xyz>2025-07-03 10:56:21 +0300
committerDawid Rycerz <dawid@rycerz.xyz>2025-07-03 10:56:21 +0300
commit456cf011b36de91c9936994b1fa45703adcd309b (patch)
tree8e60daf998f731ac50d100fa490eaecae1168042 /src/pages/posts/[...slug].astro
Initial fork of chrismwilliams/astro-theme-cactus theme
Diffstat (limited to 'src/pages/posts/[...slug].astro')
-rw-r--r--src/pages/posts/[...slug].astro24
1 files changed, 24 insertions, 0 deletions
diff --git a/src/pages/posts/[...slug].astro b/src/pages/posts/[...slug].astro
new file mode 100644
index 0000000..ca9c491
--- /dev/null
+++ b/src/pages/posts/[...slug].astro
@@ -0,0 +1,24 @@
+---
+import { render } from "astro:content";
+import { getAllPosts } from "@/data/post";
+import PostLayout from "@/layouts/BlogPost.astro";
+import type { GetStaticPaths, InferGetStaticPropsType } from "astro";
+
+// if you're using an adaptor in SSR mode, getStaticPaths wont work -> https://docs.astro.build/en/guides/routing/#modifying-the-slug-example-for-ssr
+export const getStaticPaths = (async () => {
+ const blogEntries = await getAllPosts();
+ return blogEntries.map((post) => ({
+ params: { slug: post.id },
+ props: { post },
+ }));
+}) satisfies GetStaticPaths;
+
+type Props = InferGetStaticPropsType<typeof getStaticPaths>;
+
+const { post } = Astro.props;
+const { Content } = await render(post);
+---
+
+<PostLayout post={post}>
+ <Content />
+</PostLayout>